package com.ruoyi.system.domain;

import java.math.BigDecimal;
import java.util.Date;

import com.baomidou.mybatisplus.annotation.TableField;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.core.domain.BaseEntity;

/**
 * 项目收入支出流水对象 t_sp_project_detail
 * 
 * @author ruoyi
 * @date 2024-03-21
 */
@Data
@AllArgsConstructor
@NoArgsConstructor
public class TSpProjectDetail extends BaseEntity
{
    private static final long serialVersionUID = 1L;

    /** id */
    private String pdetailId;

    /** 项目ID */
    @Excel(name = "项目ID")
    private Long projectId;

    /** 项目 */
    @Excel(name = "项目")
    private String projectName;

    /** 银行ID */
    private Long bankId;

    /** 银行 */
    @Excel(name = "银行")
    private String bankName;

    /** 费用类别ID */
    private Long costId;

    /** 费用类别 */
    @Excel(name = "费用类别")
    private String costName;

    /** 费用类别：1=收入，2=支出 */
//    @Excel(name = "费用类别：1=收入，2=支出")
    private String costType;

    /** 凭证编号 */
    @Excel(name = "凭证编号")
    private String voucherNum;

    /** 摘要说明 */
    @Excel(name = "摘要说明")
    private String description;

    /** 收款单位 */
    @Excel(name = "收款单位")
    private String payCompany;

    /** 收支实际日期 */
    @JsonFormat(pattern = "yyyy-MM-dd")
    @Excel(name = "收支实际日期", width = 30, dateFormat = "yyyy-MM-dd")
    private Date costDate;

    /** 收支金额 */
//    @Excel(name = "收支金额")
    private BigDecimal costMoney;

    /** 支出金额 */
    @Excel(name = "支出金额")
    private BigDecimal costMoneyOut;

    /** 收入金额 */
    @Excel(name = "收入金额")
    private BigDecimal costMoneyIn;


    /** 银行余额 */
    @Excel(name = "银行余额")
    private BigDecimal bankExistMoney;


    /** 备注 */
    @Excel(name = "备注")
    private String remark;

    /** 创建时间 */
    @JsonFormat(pattern = "yyyy-MM-dd")
    private Date createDate;

    /** 创建人 */
    private String createPerson;

    /** 修改时间 */
    @JsonFormat(pattern = "yyyy-MM-dd")
    private Date updateDate;

    /** 修改人 */
    private String updatePerson;


    /** 转出银行ID  内部转账使用*/
    private Long outBankId;


    /** 流水类别：1=共用，2=私用 */
    private String detailType;


    /** 最小金额 */
    @TableField(exist = false)
    private BigDecimal minMoney;

    /** 最小金额 */
    @TableField(exist = false)
    private BigDecimal maxMoney;
}
